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(57) Abstract 

A telecommunications switching system (10) employing multi-protocol routing optimization which utilizes predetermined and 
measured parameters in accordance with a set of user priorities in determining the selection of a telecommunications path to be utilized 
for transmitting a data file to a remote destination. The switching system (10) has a first memory (30) for storing the data file, a second 
memory (22) for storing predetermined parameters, a third memory for storing a set of user priorities (32), means (24) for measuring the 
value of variable parameters associated with each of the telecommunications paths, and a processor means (26) are operatively associated 
with the second and third memories (22 and 23) and the variable parameters for determining which of the plurality of telecommunications 
paths should be utilized. 
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MTTT.TT- PROTOCOL TELECOMMUNICATIONS ROUTING OPTIMIZATION 



CROSS-REFERENCE T O RELATED APPLICATION 

This application is based on and claims the 
priority of co-pending patent application filed in the 
United States Patent and Trademark Office on October 31, 
1996 and assigned Serial No. 08/741,130. 

TECHNICAL FIELD 

This invention relates to telecommunications, and 
in particular to a method and apparatus for dynamically 
selecting an optimal telecommunications path from a 
plurality of available paths in accordance with an analysis 
of both static and dynamically changing variables and user 
priorities . 

The telecommunications industry has changed 
rapidly in recent times from the simple analog connection of 
telephones for voice communications to the present systems 
for transmitting and receiving data, facsimile, e-mail, 
video, audio, as well as voice in both analog and digital 
formats (referred to herein collectively as data) . Data may 
be transmitted in any of various formats, such as a data 
file, data packets, encapsulated packets, or data streams 
(referred to herein as a data file) . Various types of 
telecommunications systems have been and continue to be 
installed, which function as the backbone systems for 
transmission of data over numerous media. For example, data 
may be transmitted from one user to another by POTS (plain 
old telephone system) , leased lines, mobile cellular 
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networks, digital links, fiber optics, satellite links, and 
private and public packet switching networks such as the 
Internet. 

5 In addition, there exists a great amount of 

pricing competition among service providers employing 
various types of these transmission media. For example, so- 
called long distance service providers such as AT&T and MCI 
offer rates in competition with each other in order to gain 

10 greater market shares of consumer, business, non-profit 

organizations, and governmental users. As a result of the 
numerous types of telecommunications services available, as 
well as the competition between providers of these services, 
users are often faced with difficult choices regarding the 

15 selection of a service which will provide them with the best 

value . 



Often, more than one telecommunications service 
providers are available at a given time to a user for 
selection as a carrier of the data to be transmitted. For 
example, a user may subscribe to two or more long distance 
service providers, and may access either one a given time by 
first dialing the service provider's code, and then dialing 
the destination phone number. In addition, a user may have 
various types of media available for selection; i.e. the 
connection may be made via the Internet, satellite, etc. 
This is especially true in a business environment, where 
economic considerations allow numerous telecommunications 
resources to be available for use. 
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The prior art generally recognizes low cost as 
being the factor upon which routing decisions are made for 
the transmission of data. As such, so-called "least cost 
routing" facilities proliferate, allowing a call to be 
placed with a service provider that provides the least cost 
a given time. PBX (private branch exchange) systems may 
employ such a least cost routing facility that automatically 
connects the calling party to the destination number along 
the cheapest route available. 



The present invention recognizes that the best 
value for a telecommunications medium at a given time is not 
necessarily the lowest cost of the choices available. That 
is, the optimization of routing selection encompasses not 

15 only a low cost, but also takes into account other factors 

such as transmission bandwidth of the medium, its 
availability at the specific time the user needs to use it, 
its security, and its reliability. In addition, a user's 
priorities may change from time to time, and the 

20 requirements regarding the transmission of one data file may 

be different than the requirements of another file. That 
is, a user may want to transmit one file in an emergency 
situation at the fastest speed, regardless of its cost. 
Other files may need high security from being illicitly 

25 intercepted, and yet other files may only need to be 

transmitted at the lowest cost at any time in the near 
future, with no speed concerns. 

Thus, the present invention recognizes that the 
30 selection of the optimal route for data transmission at a 

given time is a dynamic analysis that must be done in real- 
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time, and must take into account various factors regarding 
the available media as well as the priorities of the user 
and of the file to be transmitted. 

U.S. Patent No. 5,337,352 discloses a PBX system 
servicing a plurality of tenants, where in each tenant may 
specify which of a plurality of routes should be selected as 
having the highest priority, then second highest priority, 
etc. The routing selections are predetermined by each 
tenant in accordance with their requirements and available 
resources, and the selections are stored in a table in the 
PBX. Once a tenant desires to place a call, the PBX looks 
in the table to determine the highest priority route for 
that particular tenant, and connects the call accordingly . 
15 If that route is not available, then the next priority 

route, according to the predetermined tenant table, is 
connected. Thus, a predetermined pecking order is 
established by each tenant and stored in the PBX. This 
system is static and not changeable on a real-time basis 
2 0 since each tenant must predetermine the priority of specific 

providers to utilize. Although the system of this patent 
checks the availability of the highest predetermined 
priority route and uses the next highest priority if it is 
unavailable, such analysis is only a discrete yes/no inquiry 
25 and does not take into account the current amount of traffic 

over the route to analyze the route's availability on a 
relative basis. 

- It is therefore an object of the present invention 
30 ... to overcome the shortcomings of the prior art systems as 
described above. 
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It is an object of the present invention to 
provide a system and method for selecting an optimal 
telecommunications path for connecting a call to a remote 
location for the transfer of a data file thereover by 
analyzing on a real-time basis a set of multiple protocols. 

It is a further object of the present invention to 
provide such a system and method for mult i -protocol route 
optimization which analyzes the priorities of a user 
regarding the transmission of a particular data file in 
determining the optimal route for the call. 

It is an even further object of the present 
invention to provide such a system and method for multi- 
protocol route optimization which analyzes various factors 
regarding the route on a real-time basis in determining the 
optimal route for the call. 

It is an even further object of the present 
invention to provide such a system and method for multi- 
protocol route optimization which allows a user to override 
preset default values and specify critical transfer 
parameters on a file-by- file basis. 

P ISCfr OS URE OF THE INVEirrXON 

In accordance with these and other objects, 
provided is a telecommunications switching system comprising 
a first memory for holding. a data file to be transferred to 
a remote destination and a plurality of interfaces coupled 
with the first memory, wherein each of the interfaces is 
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interconnected with an associated telecommunications path 
capable of transferring the data file to the remote 
destination. The switching system comprises a second memory 
for storing predetermined parameters associated with each of 
5 the telecommunications paths and means for measuring the 

value of variable parameters associated with each of the 
telecommunications paths. A third memory stores a set of 
user priorities regarding the transmission of data files. 
Processor means is operatively associated with the second 

10 and third memories and the variable parameter measuring 

means for determining which of the plurality of 
telecommunications paths should be utilized for transferring 
the data file in accordance with the set of user priorities, 
the predetermined telecommunications path parameters, and 

15 the measured variable parameters. The switching system 

further comprises input means for allowing a user to change 
the user priorities in the third memory prior to 
transmitting a file. 

20 For example, the variable parameter measuring 

means performs a measurement of the data transfer speed of 
each of the telecommunications paths, for example by a so- 
called ping test. The predetermined parameters stored in 
the second memory comprises the cost per unit time of 

25 utilizing each of the telecommunications paths, which may be 

a function of the current time of day and/or current day of 
week. The predetermined parameters stored in the second 
memory also comprises a measure of data transfer reliability 
of each of the paths as well as a measure of data transfer 

30 bandwidth of each of the paths. The switching system may 
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also comprise means for ascertaining if an interface is 
available for data file transfer at a particular time. 



In a method aspect utilizing the switching system 
5 of the present invention, provided is a method of 

determining which of a plurality of telecommunications paths 
should be utilized for transferring a data file in 
accordance with a set of user priorities, the method 
comprising the steps of measuring variable parameters for 
10 each of said paths , analyzing the measured variable 

■■< parameters and the predetermined parameters in relation to 
the user priorities; and determining which of the paths 
provides the characteristics desired by the user for 
transferring the file in accordance with the user's 
15 priorities. 

BRIEF DESCRIPTION OF THE DRAWIN Q 

Figure 1 is a functional block diagram of the 
switching system of the present invention utilizing multi- 
20 protocol routing optimization; 

Figure 2 is a flowchart of the main routine 
carried out by the present invention; and 

Figure 3 is a flowchart of the interface analysis 
subroutine carried out by the present invention. 

25 

BEST MODE FOR CARRYING OUT THE INVENT ION 

Figure 1 illustrates a block diagram of the 
telecommunications switching system 10 of the present 
invention, which may be implemented for example on a 
3 0 personal computer platform, personal digital assistant 

(PDA), dedicated system such as a PBX, or the like. The 
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switching system 10 is connected to various 
telecommunications- media in accordance with the user's 
resources. In particular, the switching system 10 may be 
configured to a high speed digital link via a Tl interface 
5 12, to a local area network (LAN) via LAN interface 14, to a 

wide area network (WAN) via a WAN interface 16, to a local 
loop in a plain old telephone system (POTS) via POTS 
interface 18, and to a wireless communication network via 
wireless interface 20. The interfaces 12, 14, 16, 18 and 20 
10 are exemplary and are provided for the purposes of 

illustrating the preferred embodiment of the present 
invention. Thus, in practice, any number of the 
aforementioned interfaces may be used alone or in any 
combination as required by the user. For example, a number 
15 of common carriers such as MCI , AT&T and SPRINT may be 

configured to the switching system 10 such that the user may 
take advantage of the relative benefits of each carrier via 
the mult i -protocol routing optimization to be described 
herein. In addition, the wireless interface 20 may be 
configured for communications by any of various types of 
electromagnetic means, such as infrared, radio frequency, 
and the like. 



20 



25 



30 



Each of the telecommunication media connected to 
the various interfaces of Figure 1 has certain parameters 
associated therewith which are implemented by the routing 
methodology of the present invention. These parameters are 
classified by the routing methodology as being either 
predetermined (fixed) or measurable (variable) . Data 
regarding the predetermined parameters are stored in a 
memory 22 in the switching system 10, while data regarding 
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the measurable parameters must be collected by path analysis 
block 24 from each interface in real-time at or about the 
time the data file is transferred in order for the routing 
methodology to make a proper analysis. 



Predetermined parameters stored in memory 3 2 
include, but are not limited to, the following: 



TABLE A 



10 



$maxbandwidth ( i ) 



maximum amount of bandwidth available 

for interface (i) .For example, a 2 8.8 kbs 
modem would have a $maxbandwidth 
variable set to 28.8. 



15 



20 



25 



30 



35 



40 



$reliability (i) : 



$economy (i) 



$availability ( i) 



$security (i) 



an indication of the reliability of ^ 
interfaced) according to the following 
scale: 

10 = non-reliable transfer (wireless) 
50 = moderately reliable (e.g. modem) 
75 = very reliable (e.g. Tl, WAN) 
100 = ultra reliable (e.g. Ethernet LAN) 

the currency expenditure of interfaced) 
for a period of time, normalized so 
that a high cost interface yields a 
low measure of economy: 
$economy (i) = 100 - cost /minute 

the availability of interfaced) to a 
particular user. Not all users of the 
system will have access to each 
interface; e.g. in a shared PBX 
environment only certain subscribers may 
have access to the Tl interface. 
$availability = 0 Not available 

$availability = 1 Available 

an indication of the relative data 
security of the path, which may for 
example be a function of the number of 
bits in an encryption key (e.g. 1024) 
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Measurable parameters include, but are not limited 
to the following: 



10 



15 



20 



25 



30 



35 



TABLE B 



$present state ( i ) 



$avgstate (i) 
$datasize (i) 
$latency (i) 



$time 

$availbandwidth (i) 



the present state of interfaced), 

indicating if the telecommunications 

path is presently operational . 
$presentstate = 0 Not operational 

$presentstate = 1 Operational 

average of $present state (i) over prior 
five minute window 

the size in KB of the data file to be 
transmitted. 

measure in msec of delay through 
path(i). This is based on a real-time 
test on the interface such as by a so- 
called ping to the remote host . 

time of day/ day of week; this is the 
same for all interfaces. 

available bandwidth of interface (i) at 
a given time of file transfer 



Rather than simply relying on preprogrammed "least 
cost 1 ' routing criteria, the present invention utilizes all 
or a logical subset of the variables set forth in the Tables 
A and B above to arrive at a routing decision for a data 
file to be transmitted. That is, by employing the multi- 
protocol routing optimization of the present invention, the 
path chosen for transmission of a data file takes into 
account parameters which vary in real-time, thus not relying 
on a simple preprogrammed look-up table of low cost 
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providers as in the prior art. In addition, the user can 
specify his priorities as to the parameters which are 
critical in transmitting a particular file, i.e. low cost, 
high speed, reliability, security, etc., in making the 
5 routing determination. 

The methodology employed by the present invention 
is processed by routing optimization block 26 (which may be 
implemented in a microprocessor) and utilizes two main 
10 components comprising the parameters set forth in the Tables 

A and B above in varying combinations. The first component 
is a measure of an inherent efficiency and desirability of a 
particular telecommunications path, and is given by the 
following equation : 

15 

(1) $prevalue(i) = $maxbandwidth (i) + $reliability (i) + $economy(i) 

+ $security(i) 

The variable $prevalue is a linear value that increases with 
20 a high bandwidth, a high reliability, a high measure of 

economy (low cost) and/or a high degree of security of a 
particular path. This variable is essentially unchanging 
for a given path, except for the fact that the $economy 
parameter is based in part on the $time variable (cost of 
25 the path is a function of the time of day/ day of week) 

which is derived from a real-time clock 28. 

The second component utilized by the routing 
methodology of the present invention is based in part upon 
30 real-time parameters that may exhibit a wide variance due to 
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numerous reasons, some of which may be beyond the control of 
the user: 

(2) $currentvalue (i) = $economy(i) x $speed(i) + $avgstate(i) x 

5 10 

where $speed(i) = 10,000 - ($datasize (i) x $latency(i) x 100) 

so that : 

$currentvalue(i) = $economy (i) x (10 , 000 - ( $datasize ( i) x $latency(i) x 
10 100) + $avgstate(i) x 10 



Thus, the $currentvalue ( i) for a given path (i) will be 
higher for the path having a greater economy (low cost) , a 
15 low data file size, and/or little latency through the path 

(high speed) . 

The selection of the optimal route to use is then 
a combination of the values calculated above in equations 
20 (1) and (2) : 

(3) $f inalvalue (i) = $prevalue(i) + $ current value (i) 

= $maxbandwidth(i) + $reliability (i) + $economy(i) 
+ $security(i) 

25 + ($economy(i)x(l0,000 - ( $datasize (i) x 

$latency(i) x 100) 
+ $avgstate(i) x 10) 



3 0 The routing optimization methodology block 26 then 

takes the highest $f inalvalue (i) for each path in the system 
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that is available, operational, and meets a threshold 
($avgstate x 10) value of 25 or above as shown in the 
flowcharts to be described below. This methodology thereby 
allows the optimal selection based on an analysis of 
5 multiple protocols employed by the system, rather than 

simply a least cost routing decision. 

Path analysis function block 24 obtains the value 
$latency(i) for each path(i) by any means known in the art 

10 for obtaining the latency of an IP addressable path, such as 

by well known software utility known as "ping." The ping 
routine sends a packet onto the network and obtains a value 
of the average delay encountered by that packet in reaching 
the destination and returning. Other techniques which allow 

15 the system to obtain a measure of the latency of the path . 

are also encompassed by the present invention. 
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A user may customize the relative weights given to 
each of the variables set forth in Tables A, B in accordance 
with his specific requirements as stored in user priorities 
5 memory 32. These fixed weighting values would be stored in 

a memory in the switching system and used in conjunction 
with the routing methodology for all files transferred in 
accordance with the invention. The weighting values are 
used as multipliers for the variables in the algorithm in 

10 order to allow the user to customize the algorithm as 

desired. For example, a user may want to emphasize the 
$security(i) parameter in the analysis, and may then specify 
a weight multiplier of (for example) two so that the 
$security(i) parameter is weighted twice as much as if the 

15 $security(i) parameter were left in the default state. 
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In addition, a user may override via input to a 
user interface 34 the fixed parameter weights preprogrammed 
in memory for any given file transfer with temporary values. 
5 The user interface may be any type of device for allowing 

the user to input data, such as a keyboard, mouse, etc. 

In another form of parameter weighting, the user 
may also force the program to ignore certain parameters and 

10 focus on one parameter only in arriving at a routing 

decision. For example, if a user wants to transmit a data 
file 30 to a remote location via the fastest path, 
regardless of cost or any other factor, then the user 
specifies this requirement to the routing optimization block 

15 26 via the interface 34. The routing optimization block 26 % 

will then cause all variables except for $latency to a 
predetermined factor, so that the path with the smallest 
value for $latency (i.e. the smallest routing delay) will be 
chosen by the routing optimization block 26 as being the 

20 fastest route. 

Other permutations and variations of the above 
example can be easily derived by one skilled in the art to 
allow the user to specify his priorities as to data transfer 
25 of a file at any given point in time, e.g. the analysis may 

be forced to look at any two variables, etc. 

In addition, a user may store certain sets of 
parameter weighting to be used in different situations, and 
30 . then select the set when desired. The set of weights would 

then be applied as above described. Furthermore, the 
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program may be configured to automatically apply certain 
weighting sets as a function of the data type. For example, 
the user may specify that all facsimile messages be given a 
high economy factor, while all video files be given a low 
5 security factor, etc . 

Figures 2 and 3 illustrate flowcharts of the 
methodology employed by the present invention in arriving at 
the optimal choice for routing a data file amongst a 

10 plurality of available paths in accordance with the present 

invention. First, as shown in Figure 2, the fixed user 
priorities are fetched so that the parameters used in the 
analysis may be weighted accordingly. The user is then 
allowed to enter his temporary priority override values for 

15 the file transfer. Assuming for this example that no fixed 

weighting or temporary override values are entered, then the 
$finalvalue parameter is determined for each of the paths (i) 
in the switching system 10 in the following manner. 

2 0 First, with reference to Figure 3, the routing 

optimization block 2 6 checks with memory 22 to determine if 
that interfaced) has been programmed as being available to 
be used by that user be observing the variable 
$availability (i) . For example, if the switching system 10 

25 is embodied in a PBX system, then not all users will have 

access to all paths (i) due to their economic resources. 
This information is contained in memory 22 and checked as a 
first step in the process of Figure 3 . 



30 



If $availability (i) =0, then $f inalvalue (i) is set 
to zero and the routine is exited. If, however, the 
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interface (i) is avialable, the $availabilty (i) is set to 1 
and the process proceeds. The routine then checks the to see 
if the path(i) is operable at that time, and the 
$present state variable is returned from the $interf ace (i) 
5 accordingly. If $presentstate (i) =0 (path inoperable or 

down), then $f inalvalue (i) is set to zero and the routine is 
exited. If $presentstate (i) =1 (path operable or up), then 
the routine proceeds. 

10 The variable $avgstate is then checked to ensure 

that it is greater than a predetermined threshold value, e.g 
if $avgstate x 10 > 25. If this is true, then the 
interface (i) is considered to be essentially in operable 
condition. If false, then the interface (i) is considered to 

15 be in essentially non-operable condition, notwithstanding 

the fact that the $presentstate indicates operability at 
that particular time. 

The routine then proceeds to obtain the 
20 $latency(i) value via path analysis block 24. Using 

$latency(i), the variable $speed(i) is calculated as shown 
in the flowchart and explained above. The variable 
$economy(i), which is a function of the $time variable, is 
obtained from the memory 22. Then, the variable 
25 $currentvalue (i) is calculated as a function of $economy(i), 

$speed(i) , and $avgstate (i) . 

The variable $prevalue(i) is then calculated as a 
function of the variables $maxbandwidth (i) , $reliability(i) , 
30 and $security (i) , which are obtained from the memory 26, as 

well as $economy(i) which was previously determined. 
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Finally, the variable $finalvalue is obtained as shown in 
the routine, and this is stored in a register pending 
calculation of $f inalvalue ( i ) for the remaining interfaces 
as shown in Figure 2 . 

After all the interfaces have been analyzed in the 
above manner, then the routing optimization block 26 makes a 
determination as which interfaced) should be selected in 
accordance with the highest- value for $f inalvalue (iK The 
data file is then routed from the memory 3 0 to the selected 
interface for transmission. 



The routines shown in Figures 2 and 3 may be 
supplemented by the user priority override features 
15 described above, which allow the user to specify the fastest 

route, the least cost rout, the most reliable route, etc. 

The measurable parameter $availbandwidth (i) may 
also be utilized in the algorithms presented herein to 
20 provide a real-time indication of the desirability of 

selecting a particular interfaced) at a given time. 
Although the fixed parameter $maxbandwidth (i) provides a 
measure of the maximum bandwidth that may be available for a 
given interface, the interface can be tested if desired in 
25 order to determine what portion of that bandwidth is 

actually available for use. One test known in the art for 
accomplishing this measurement is the so-called "show 
interface serial zero" test, which may be performed by 
measuring the amount of packets received in the last n 
seconds as well as how many packets have been transmitted on 
the interface in that time. Thus, the parameter 
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$availbandwidth may be used instead of, or in conjunction 
with, the measured parameter $latency to perform the 
analysis herein. 

5 In addition, while the system and method of the 

present invention has been shown in conjunction with the 
transmission of one data file (as defined herein) , it may be 
also applicable to the transmission of multiple data files 
in either a serial or parallel (interleaved) basis, by 
10 modification of the algorithm and routines as may be 

appropriate . 

The choice of particular variables and parameters 
used herein is the preferred embodiment; it is anticipated 

15 that other variables may be used in conjunction with the ■ 

present invention to arrive at the optimal route . in a given* 
situation. In addition, the particular algorithm, while 
determined to provide a requisite relative weighting of the 
fixed and measured variables, may also be supplemented in " 

20 accordance with the requirements of the user in order to 

arrive at the optimal routing choice. 
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CLAIMS : 

1. In a telecommunications switching system comprising a 
plurality of interfaces, each of said interfaces 

5 interconnected with an associated telecommunications path 

capable of transferring a data file to a remote destination, 
each of said telecommunications paths having predetermined 
parameters associated therewith stored in a memory in said 
switching system and variable parameters associated 
10 therewith, a method of determining which of said plurality 

of telecommunications paths should be utilized for 
transferring a data file, said method comprising the steps 
Of: 

a) measuring said variable parameters for each 
15 of said paths; 

b) analyzing said measured variable parameters 
and said predetermined parameters ; and 

c) determining which of said paths provides an 
optimal set of characteristics for transferring the file to 

20 the remote destination. 

2. The method of claim 1 in which said determining step 
analyzes a set of programmed user priorities in determining 
which of said paths provides the optimal set of 

25 characteristics for transferring the file to the remote 

destination. 

3 . The method of claim 2 in which the user priorities are 
predefined and stored in said switching system memory. 

30 . 
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4. The method of claim 3 in which said predefined user 
priorities may be changed by said user prior to said 
analysis step. 

5 5. The method of claim 2 in which telecommunications path 

variable parameters comprises the data transfer speed of 
said path at a given point in time. 

6. The method of claim 2 in which said telecommunications 
10 path predetermined parameters comprises the cost per unit 

time of utilizing said path. 

7. The method of claim 6 in which said cost per unit time 
is a function of the current time of day. 

15 

8. The method of claim 6 in which said cost per unit time 
is a function of the current day of week. 

9. The method of claim 1 in which said telecommunications 
20 path predetermined parameters comprises a measure of data 

transfer reliability of said path. 

10. The method of claim 1 in which said telecommunications 
path predetermined parameters comprises a measure of data 

25 transfer bandwidth of said path. 

11. The method of claim 2 further comprising the step of 
analyzing the size of the file to be sent in relation to 
said user priorities . 

30 . 



21 



BMSOOCID. <WO 9819439A1 J_> 



WO 98/19439 



PCT/US97/19624 



12, The method of claim 1 comprising the additional step of 
first ascertaining if an interface is available prior to 
performing said analysis. 

5 13. The method of claim 3 in which each of said 

predetermined and measured parameters are weighted with 
respect to said user priorities in performing said analysis 
step. 

10 14 . A telecommunications switching system comprising: 

a) a first memory for holding a data file to be 
transferred to a remote destination; 

b) a plurality of interfaces coupled with* said * 
first memory, each of said interfaces interconnected 

15 with an associated telecommunications path capable of 

transferring the data file with the remote destination; 

c) a second memory for storing predetermined 
parameters associated with each of said 
telecommunications paths; 

20 d) means for measuring the value of a variable 

parameter associated with each of said 
telecommunications paths; and 

e) processor means operatively associated with 
said second and third memories and said variable 

25 parameter measuring means for determining which of said 

plurality of telecommunications paths should be 
utilized for transferring the data file in accordance 
with said predetermined telecommunications path 
parameters and said measured variable parameters. 

30 
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15. The system of claim 14 further comprising a third 
memory for storing a set of user priorities regarding the 
transmission of data files, and wherein said processor means 
determines which of said plurality of telecommunications 

5 paths should be utilized for transferring the data file in 

accordance with said user priorities. 

16. The switching system of claim 15 further comprising 
input means for allowing a user to change said user 

10 priorities in said third memory. 

17. The switching system of claim 15 in which said variable 
parameter measuring means performs a measurement of the data 
transfer speed of each of said telecommunications paths. 

15 

18. The switching system of claim 16 in which said data 
transfer speed measurement is performed by a ping test. 

19. The switching system of claim 15 in which the 

2 0 predetermined parameters stored in said second memory 

comprises the cost per unit time of utilizing the 
telecommunications paths. 

20. The switching system of claim 19 in which the cost per 
25 unit time is a function of the current time of day. 

21. The switching system of claim 19 in which the cost per 
unit time is a function of the current day of week. 

30 22. The switching system of claim 15 in which the 

predetermined parameters stored in said second memory 
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comprises a measure of data transfer reliability of each of 
said paths . 



23. The switching system of claim 15 in which the 

5 predetermined parameters stored in said second memory 

comprises a measure of data transfer bandwidth of each of 
said paths. 



24. The switching system of claim 15 further comprising 
10 means for ascertaining if an interface is available for data 

file transfer. 
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